<?php

namespace app\admin\model\manufacture;

use think\Model;

class PlanDetail extends Model
{
    // 表名
    protected $name = 'manufacture_plan_detail';
    
    // 自动写入时间戳字段
    protected $autoWriteTimestamp = 'int';

    // 定义时间戳字段名
    protected $createTime = 'createtime';
    
    // 追加属性
    protected $append = [
        'status_text'
    ];
    
    // 状态
    public function getStatusList()
    {
        return [
            '0' => __('待执行'),
            '1' => __('执行中'),
            '2' => __('已完成')
        ];
    }

    public function getStatusTextAttr($value, $data)
    {
        $value = $value ? $value : $data['status'];
        $list = $this->getStatusList();
        return isset($list[$value]) ? $list[$value] : '';
    }

    // 关联计划
    public function plan()
    {
        return $this->belongsTo('Plan', 'plan_id', 'id');
    }

    // 关联产品型号
    public function model()
    {
        return $this->belongsTo('app\admin\model\scanwork\ProductModel', 'model_id', 'id');
    }

    // 关联工序
    public function process()
    {
        return $this->belongsTo('app\admin\model\scanwork\Process', 'process_id', 'id');
    }

    // 获取进度百分比
    public function getProgressAttr($value, $data)
    {
        if ($data['planned_quantity'] == 0) {
            return 0;
        }
        return round(($data['completed_quantity'] / $data['planned_quantity']) * 100, 2);
    }

    // 获取剩余数量
    public function getRemainingQuantityAttr($value, $data)
    {
        return $data['planned_quantity'] - $data['completed_quantity'];
    }
}
